cssnode: Change get_style_provider() vfunc
authorBenjamin Otte <otte@redhat.com>
Tue, 17 Feb 2015 14:18:32 +0000 (15:18 +0100)
committerBenjamin Otte <otte@redhat.com>
Wed, 18 Mar 2015 14:23:32 +0000 (15:23 +0100)
Instead of always returning a provider, allow the vfunc to return NULL
to mane "use same provider as parent". This allows a bunch of
optimizations.

gtk/gtkcssnode.c
gtk/gtkcssnodeprivate.h
gtk/gtkcsspathnode.c
gtk/gtkcsswidgetnode.c

index 877dd182d8bdd67d81453435588a1d0d1fba63a6..d81f061a9ebd6b21f88fd2fdd0b05d7c171a8583 100644 (file)
 
 G_DEFINE_TYPE (GtkCssNode, gtk_css_node, G_TYPE_OBJECT)
 
+static GtkStyleProviderPrivate *
+gtk_css_node_get_style_provider_or_null (GtkCssNode *cssnode)
+{
+  return GTK_CSS_NODE_GET_CLASS (cssnode)->get_style_provider (cssnode);
+}
+
 void
 gtk_css_node_set_invalid (GtkCssNode *node,
                           gboolean    invalid)
@@ -82,13 +88,15 @@ gtk_css_node_finalize (GObject *object)
 static gboolean
 may_use_global_parent_cache (GtkCssNode *node)
 {
+  GtkStyleProviderPrivate *provider;
   GtkCssNode *parent;
   
   parent = gtk_css_node_get_parent (node);
   if (parent == NULL)
     return FALSE;
 
-  if (gtk_css_node_get_style_provider (node) != gtk_css_node_get_style_provider (parent))
+  provider = gtk_css_node_get_style_provider_or_null (node);
+  if (provider != NULL && provider != gtk_css_node_get_style_provider (parent))
     return FALSE;
 
   return TRUE;
@@ -275,10 +283,7 @@ gtk_css_node_real_get_widget_path (GtkCssNode *cssnode)
 static GtkStyleProviderPrivate *
 gtk_css_node_real_get_style_provider (GtkCssNode *cssnode)
 {
-  if (cssnode->parent)
-    return gtk_css_node_get_style_provider (cssnode->parent);
-
-  return GTK_STYLE_PROVIDER_PRIVATE (_gtk_settings_get_style_cascade (gtk_settings_get_default (), 1));
+  return NULL;
 }
 
 static void
@@ -821,5 +826,14 @@ gtk_css_node_get_widget_path (GtkCssNode *cssnode)
 GtkStyleProviderPrivate *
 gtk_css_node_get_style_provider (GtkCssNode *cssnode)
 {
-  return GTK_CSS_NODE_GET_CLASS (cssnode)->get_style_provider (cssnode);
+  GtkStyleProviderPrivate *result;
+  
+  result = gtk_css_node_get_style_provider_or_null (cssnode);
+  if (result)
+    return result;
+
+  if (cssnode->parent)
+    return gtk_css_node_get_style_provider (cssnode->parent);
+
+  return GTK_STYLE_PROVIDER_PRIVATE (_gtk_settings_get_style_cascade (gtk_settings_get_default (), 1));
 }
index 32f938f130c0e88c47f12249996a39a730734723..8cfcd2a9c0504f83f9e2702d61b772036e878faa 100644 (file)
@@ -68,6 +68,7 @@ struct _GtkCssNodeClass
                                                          GtkCssMatcher         *matcher);
   GtkWidgetPath *       (* create_widget_path)          (GtkCssNode            *cssnode);
   const GtkWidgetPath * (* get_widget_path)             (GtkCssNode            *cssnode);
+  /* get style provider to use or NULL to use parent's */
   GtkStyleProviderPrivate *(* get_style_provider)       (GtkCssNode            *cssnode);
   GtkCssStyle *         (* update_style)                (GtkCssNode            *cssnode,
                                                          GtkCssChange           pending_changes,
index 1fc702e22d31a9604cc3a2922c28ac4994f6c44b..50a1cc3e08ebcd364a62098a9c681eb252b24504 100644 (file)
@@ -107,7 +107,7 @@ gtk_css_path_node_get_style_provider (GtkCssNode *node)
   GtkCssPathNode *path_node = GTK_CSS_PATH_NODE (node);
 
   if (path_node->context == NULL)
-    return GTK_CSS_NODE_CLASS (gtk_css_path_node_parent_class)->get_style_provider (node);
+    return NULL;
 
   return gtk_style_context_get_style_provider (path_node->context);
 }
index 12e346b278b2f51fcaa0fbbbd36deb67590706cd..10d0334f7ebee3d01277a83c0dc8b24e1ee54f80 100644 (file)
@@ -262,7 +262,7 @@ gtk_css_widget_node_get_style_provider (GtkCssNode *node)
   GtkCssWidgetNode *widget_node = GTK_CSS_WIDGET_NODE (node);
 
   if (widget_node->widget == NULL)
-    return GTK_CSS_NODE_CLASS (gtk_css_widget_node_parent_class)->get_style_provider (node);
+    return NULL;
 
   return gtk_style_context_get_style_provider (gtk_widget_get_style_context (widget_node->widget));
 }